import multiprocessing
import sys
from time import sleep
from datetime import datetime, time
from logging import INFO

from vnpy.event import EventEngine
from vnpy.trader.setting import SETTINGS
from vnpy.trader.engine import MainEngine
from vnpy.trader.constant import Exchange
from vnpy.trader.object import SubscribeRequest

from vnpy_ctp import CtpGateway
from vnpy_ctastrategy import CtaStrategyApp
from vnpy_ctastrategy.base import EVENT_CTA_LOG

from vnpy_datamanager import DataManagerApp
from vnpy_datarecorder import DataRecorderApp
# from vnpy_riskmanager import RiskManagerApp
from vnpy_webtrader import WebTraderApp

SETTINGS["log.active"] = True
SETTINGS["log.level"] = INFO
SETTINGS["log.console"] = True


ctp_setting = {
    "用户名": "226992",
    "密码": "",
    "经纪商代码": "9999",
    "交易服务器": "tcp://218.202.237.33:10203",
    "行情服务器": "tcp://218.202.237.33:10213",
    "产品名称": "simnow_client_test",
    "授权编码": "0000000000000000",
    "产品信息": ""
}


# Chinese futures market trading period (day/night)
DAY_START = time(8, 45)
DAY_END = time(15, 0)

NIGHT_START = time(19, 45)
NIGHT_END = time(2, 45)


def check_trading_period():
    """"""
    current_time = datetime.now().time()

    trading = False
    if (
        (current_time >= DAY_START and current_time <= DAY_END)
        or (current_time >= NIGHT_START)
        or (current_time <= NIGHT_END)
    ):
        trading = True

    return trading


def run_child():
    """
    Running in the child process.
    """
    SETTINGS["log.file"] = True

    event_engine = EventEngine()
    main_engine = MainEngine(event_engine)
    main_engine.add_gateway(CtpGateway)
    cta_engine = main_engine.add_app(CtaStrategyApp)
    datamage_engine = main_engine.add_app(DataManagerApp)
    datarecorder_engine = main_engine.add_app(DataRecorderApp)
    webtrade_engine = main_engine.add_app(WebTraderApp)
    main_engine.write_log("主引擎创建成功")

    log_engine = main_engine.get_engine("log")
    event_engine.register(EVENT_CTA_LOG, log_engine.process_log_event)
    main_engine.write_log("注册日志事件监听")

    main_engine.connect(ctp_setting, "CTP")
    main_engine.write_log("连接CTP接口")

    sleep(10)

    # 订阅
    main_engine.write_log("subscribe c2411.DCE")
    main_engine.subscribe(SubscribeRequest(symbol="c2411", exchange=Exchange.DCE), "CTP")
    main_engine.write_log("subscribe c2501.DCE")
    main_engine.subscribe(SubscribeRequest(symbol="c2501", exchange=Exchange.DCE), "CTP")
    main_engine.write_log("subscribe c2503.DCE")
    main_engine.subscribe(SubscribeRequest(symbol="c2503", exchange=Exchange.DCE), "CTP")
    main_engine.write_log("subscribe c2505.DCE")
    main_engine.subscribe(SubscribeRequest(symbol="c2505", exchange=Exchange.DCE), "CTP")
    main_engine.write_log("subscribe c2507.DCE")
    main_engine.subscribe(SubscribeRequest(symbol="c2507", exchange=Exchange.DCE), "CTP")
    main_engine.write_log("subscribe c2509.DCE")
    main_engine.subscribe(SubscribeRequest(symbol="c2509", exchange=Exchange.DCE), "CTP")

    main_engine.write_log("start init cta strategy engine")
    cta_engine.init_engine()
    main_engine.write_log("CTA策略初始化完成")

    main_engine.write_log("start init all strategy")
    cta_engine.init_all_strategies()
    sleep(30)   # Leave enough time to complete strategy initialization
    main_engine.write_log("CTA策略全部初始化")

    main_engine.write_log("start run all strategy")
    cta_engine.start_all_strategies()
    main_engine.write_log("CTA策略全部启动")

    while True:
        sleep(10)

        trading = check_trading_period()
        if not trading:
            print("关闭子进程")
            main_engine.close()
            sys.exit(0)


def run_parent():
    """
    Running in the parent process.
    """
    print("启动CTA策略守护父进程")

    child_process = None

    while True:
        trading = check_trading_period()

        # Start child process in trading period
        if trading and child_process is None:
            print("启动子进程")
            child_process = multiprocessing.Process(target=run_child)
            child_process.start()
            print("子进程启动成功")

        # 非记录时间则退出子进程
        if not trading and child_process is not None:
            if not child_process.is_alive():
                child_process = None
                print("子进程关闭成功")

        sleep(5)


if __name__ == "__main__":
    run_parent()
